home *** CD-ROM | disk | FTP | other *** search
/ Amiga Tools 4 / Amiga Tools 4.iso / tools / dfue / term 4.6(?) / extras / source / term-source.lha / PrintPanel.c < prev    next >
C/C++ Source or Header  |  1996-03-18  |  7KB  |  305 lines

  1. /*
  2. **    PrintPanel.c
  3. **
  4. **    Control panel to set options for phonebook printing
  5. **
  6. **    Copyright © 1990-1996 by Olaf `Olsen' Barthel
  7. **        All Rights Reserved
  8. */
  9.  
  10. #ifndef _GLOBAL_H
  11. #include "Global.h"
  12. #endif
  13.  
  14. enum    {    GAD_FILE=1, GAD_PLAIN, GAD_USE, GAD_CANCEL, GAD_OPTION };
  15.  
  16. STATIC UBYTE    OutputFile[MAX_FILENAME_LENGTH] = "PRT:";
  17. STATIC ULONG    Flags = PRINT_SERIAL | PRINT_MODEM | PRINT_SCREEN | PRINT_TERMINAL | PRINT_USERNAME | PRINT_COMMENT;
  18. STATIC BOOLEAN    Plain = FALSE;
  19.  
  20. VOID
  21. PrintPanel(struct Window *Window,struct List *PhoneList,LONG Count)
  22. {
  23.     struct LayoutHandle    *Handle;
  24.     BOOL             Result = FALSE;
  25.  
  26.     if(Handle = LT_CreateHandleTags(Window -> WScreen,
  27.         LH_LocaleHook,    &LocaleHook,
  28.     TAG_DONE))
  29.     {
  30.         struct Window    *PanelWindow;
  31.         BYTE         Storage[6];
  32.  
  33.         LT_New(Handle,
  34.             LA_Type,    VERTICAL_KIND,
  35.         TAG_DONE);
  36.         {
  37.             LT_New(Handle,
  38.                 LA_Type,    HORIZONTAL_KIND,
  39.                 LA_LabelID,    MSG_V36_0152,
  40.             TAG_DONE);
  41.             {
  42.                 LT_New(Handle,
  43.                     LA_Type,    VERTICAL_KIND,
  44.                 TAG_DONE);
  45.                 {
  46.                     LONG i;
  47.  
  48.                     for(i = 0 ; i < 6 ; i++)
  49.                     {
  50.                         if(i == 3)
  51.                         {
  52.                             LT_EndGroup(Handle);
  53.  
  54.                             LT_New(Handle,
  55.                                 LA_Type,VERTICAL_KIND,
  56.                             TAG_DONE);
  57.                         }
  58.  
  59.                         if(Flags & (1L << i))
  60.                             Storage[i] = TRUE;
  61.                         else
  62.                             Storage[i] = FALSE;
  63.  
  64.                         LT_New(Handle,
  65.                             LA_Type,    CHECKBOX_KIND,
  66.                             LA_LabelID,    MSG_PRINTPANEL_INCLUDE_SERIAL_GAD + i,
  67.                             LA_ID,        GAD_OPTION + i,
  68.                             LA_BYTE,    &Storage[i],
  69.                         TAG_DONE);
  70.                     }
  71.  
  72.                     LT_EndGroup(Handle);
  73.                 }
  74.  
  75.                 LT_EndGroup(Handle);
  76.             }
  77.  
  78.             LT_New(Handle,
  79.                 LA_Type,    VERTICAL_KIND,
  80.                 LA_LabelID,    MSG_V36_0153,
  81.             TAG_DONE);
  82.             {
  83.                 LT_New(Handle,
  84.                     LA_Type,    STRING_KIND,
  85.                     LA_LabelID,    MSG_PRINTPANEL_OUTPUT_FILE_OR_DEVICE_GAD,
  86.                     LA_ID,        GAD_FILE,
  87.                     LA_STRPTR,    OutputFile,
  88.                     LA_Chars,    30,
  89.                     LAST_Picker,    TRUE,
  90.                     GTST_MaxChars,    MAX_FILENAME_LENGTH - 1,
  91.                 TAG_DONE);
  92.  
  93.                 LT_New(Handle,
  94.                     LA_Type,    CHECKBOX_KIND,
  95.                     LA_LabelID,    MSG_PRINTPANEL_PLAIN_TEXT_GAD,
  96.                     LA_ID,        GAD_PLAIN,
  97.                     LA_BYTE,    &Plain,
  98.                 TAG_DONE);
  99.  
  100.                 LT_EndGroup(Handle);
  101.             }
  102.  
  103.             LT_New(Handle,
  104.                 LA_Type,VERTICAL_KIND,
  105.             TAG_DONE);
  106.             {
  107.                 LT_New(Handle,
  108.                     LA_Type,    XBAR_KIND,
  109.                     LAXB_FullSize,    TRUE,
  110.                 TAG_DONE);
  111.  
  112.                 LT_EndGroup(Handle);
  113.             }
  114.  
  115.             LT_New(Handle,LA_Type,HORIZONTAL_KIND,
  116.                 LAGR_SameSize,    TRUE,
  117.                 LAGR_Spread,    TRUE,
  118.             TAG_DONE);
  119.             {
  120.                 LT_New(Handle,
  121.                     LA_Type,    BUTTON_KIND,
  122.                     LA_LabelID,    MSG_GLOBAL_USE_GAD,
  123.                     LA_ID,        GAD_USE,
  124.                     LABT_ReturnKey,    TRUE,
  125.                     LABT_ExtraFat,    TRUE,
  126.                 TAG_DONE);
  127.  
  128.                 LT_New(Handle,
  129.                     LA_Type,    BUTTON_KIND,
  130.                     LA_LabelID,    MSG_GLOBAL_CANCEL_GAD,
  131.                     LA_ID,        GAD_CANCEL,
  132.                     LABT_EscKey,    TRUE,
  133.                     LABT_ExtraFat,    TRUE,
  134.                 TAG_DONE);
  135.  
  136.                 LT_EndGroup(Handle);
  137.             }
  138.  
  139.             LT_EndGroup(Handle);
  140.         }
  141.  
  142.         if(PanelWindow = LT_Build(Handle,
  143.             LAWN_TitleID,        MSG_PRINTPANEL_OUTPUT_OPTIONS_TXT,
  144.             LAWN_IDCMP,        IDCMP_CLOSEWINDOW,
  145.             LAWN_HelpHook,        &GuideHook,
  146.             LAWN_Parent,        Window,
  147.             WA_DepthGadget,        TRUE,
  148.             WA_CloseGadget,        TRUE,
  149.             WA_DragBar,        TRUE,
  150.             WA_RMBTrap,        TRUE,
  151.             WA_Activate,        TRUE,
  152.             WA_SimpleRefresh,    TRUE,
  153.         TAG_DONE))
  154.         {
  155.             struct IntuiMessage    *Message;
  156.             BOOL             Done = FALSE;
  157.             ULONG             MsgClass;
  158.             struct Gadget        *MsgGadget;
  159.  
  160.             GuideContext(CONTEXT_PRINT);
  161.  
  162.             PushWindow(PanelWindow);
  163.  
  164.             do
  165.             {
  166.                 if(Wait(PORTMASK(PanelWindow -> UserPort) | SIG_BREAK) & SIG_BREAK)
  167.                     break;
  168.  
  169.                 while(Message = (struct IntuiMessage *)LT_GetIMsg(Handle))
  170.                 {
  171.                     MsgClass    = Message -> Class;
  172.                     MsgGadget    = (struct Gadget *)Message -> IAddress;
  173.  
  174.                     LT_ReplyIMsg(Message);
  175.  
  176.                     if(MsgClass == IDCMP_CLOSEWINDOW)
  177.                         Done = TRUE;
  178.  
  179.                     if(MsgClass == IDCMP_IDCMPUPDATE && MsgGadget -> GadgetID == GAD_FILE)
  180.                     {
  181.                         UBYTE             DummyBuffer[MAX_FILENAME_LENGTH],
  182.                                     *DummyChar;
  183.                         struct FileRequester    *FileRequest;
  184.  
  185.                         SplitFileName(OutputFile,&DummyChar,DummyBuffer);
  186.  
  187.                         if(!DummyChar[0])
  188.                         {
  189.                             DummyBuffer[0] = 0;
  190.  
  191.                             DummyChar = LocaleString(MSG_PRINTPANEL_FILENAME_TXT);
  192.                         }
  193.  
  194.                         if(FileRequest = GetFile(PanelWindow,LocaleString(MSG_PRINTPANEL_SELECT_OUTPUT_FILE_TXT),DummyBuffer,DummyChar,DummyBuffer,NULL,TRUE,FALSE,FALSE,LocaleString(MSG_GLOBAL_SELECT_TXT),TRUE))
  195.                         {
  196.                             LT_SetAttributes(Handle,GAD_FILE,
  197.                                 GTST_String,DummyBuffer,
  198.                             TAG_DONE);
  199.  
  200.                             FreeAslRequest(FileRequest);
  201.                         }
  202.                     }
  203.  
  204.                     if(MsgClass == IDCMP_GADGETUP)
  205.                     {
  206.                         LONG i;
  207.  
  208.                         switch(MsgGadget -> GadgetID)
  209.                         {
  210.                             case GAD_USE:
  211.  
  212.                                 LT_UpdateStrings(Handle);
  213.  
  214.                                 Flags = NULL;
  215.  
  216.                                 for(i = 0 ; i < 6 ; i++)
  217.                                 {
  218.                                     if(Storage[i])
  219.                                         Flags |= (1L << i);
  220.                                 }
  221.  
  222.                                 Result = Done = TRUE;
  223.                                 break;
  224.  
  225.                             case GAD_CANCEL:
  226.  
  227.                                 Done = TRUE;
  228.                                 break;
  229.                         }
  230.                     }
  231.                 }
  232.             }
  233.             while(!Done);
  234.  
  235.             PopWindow();
  236.         }
  237.  
  238.         LT_DeleteHandle(Handle);
  239.     }
  240.  
  241.     if(Result)
  242.     {
  243.         LONG Error = 0;
  244.         BPTR File;
  245.  
  246.         if(File = Open(OutputFile,MODE_NEWFILE))
  247.         {
  248.             struct Window        *ReqWindow;
  249.             struct EasyStruct     Easy;
  250.  
  251.             Easy . es_StructSize    = sizeof(struct EasyStruct);
  252.             Easy . es_Flags        = NULL;
  253.             Easy . es_Title        = (UBYTE *)LocaleString(MSG_TERMAUX_TERM_REQUEST_TXT);
  254.             Easy . es_GadgetFormat    = (UBYTE *)LocaleString(MSG_PRINT_STOP_TXT);
  255.             Easy . es_TextFormat    = (UBYTE *)LocaleString(MSG_PRINT_PRINTING_PHONEBOOK_TXT);
  256.  
  257.             if(ReqWindow = BuildEasyRequest(Window,&Easy,NULL))
  258.             {
  259.                 struct PhoneNode    *TempNode;
  260.                 BOOL             Continue = TRUE;
  261.  
  262.                 if(Count > 0)
  263.                 {
  264.                     for(TempNode = (struct PhoneNode *)PhoneList -> lh_Head ; Continue && TempNode -> VanillaNode . ln_Succ ; TempNode = (struct PhoneNode *)TempNode -> VanillaNode . ln_Succ)
  265.                     {
  266.                         if(TempNode -> Entry -> Count >= 0)
  267.                             Continue = PrintEntry(File,ReqWindow,Plain,&Error,TempNode -> Entry,Flags);
  268.                     }
  269.                 }
  270.                 else
  271.                 {
  272.                     for(TempNode = (struct PhoneNode *)PhoneList -> lh_Head ; Continue && TempNode -> VanillaNode . ln_Succ ; TempNode = (struct PhoneNode *)TempNode -> VanillaNode . ln_Succ)
  273.                         Continue = PrintEntry(File,ReqWindow,Plain,&Error,TempNode -> Entry,Flags);
  274.                 }
  275.  
  276.                 FreeSysRequest(ReqWindow);
  277.             }
  278.  
  279.             Close(File);
  280.  
  281.             if(PathPart(OutputFile) != OutputFile)
  282.             {
  283.                 AddProtection(OutputFile,FIBF_EXECUTE);
  284.  
  285.                 if(Config -> MiscConfig -> CreateIcons)
  286.                     AddIcon(OutputFile,FILETYPE_TEXT,TRUE);
  287.             }
  288.         }
  289.         else
  290.             Error = IoErr();
  291.  
  292.         if(Error)
  293.         {
  294.             STRPTR ErrorString;
  295.  
  296.             if(Fault(Error,"",SharedBuffer,MAX_FILENAME_LENGTH))
  297.                 ErrorString = SharedBuffer;
  298.             else
  299.                 ErrorString = "???";
  300.  
  301.             ShowRequest(Window,LocaleString(MSG_PRINT_ERROR_TXT),LocaleString(MSG_GLOBAL_CONTINUE_TXT),Error,ErrorString);
  302.         }
  303.     }
  304. }
  305.